import axios from 'axios'
import { Message } from 'element-ui'
import store from '@/store'

// create an axios instance
const service = axios.create({
  baseURL: 'http://120.24.171.137:1337/', // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // request timeout
})

// 添加请求拦截器
service.interceptors.request.use(function(config) {
  // 在发送请求之前做些什么
  // console.log('请求响应', config)
  const token = store.state.user.token
  if (token && config.url !== '/login' && config.url !== '/register') {
    config.headers.Authorization = `Bearer ${token}`
  }
  return config
}, function(error) {
  // 对请求错误做些什么
  return Promise.reject(error)
})

// 添加响应拦截器
service.interceptors.response.use(function(response) {
  // 2xx 范围内的状态码都会触发该函数。
  // 对响应数据做点什么
  // console.log('成功响应', response.data)
  return response.data
}, function(error) {
  // 超出 2xx 范围的状态码都会触发该函数。
  // 对响应错误做点什么
  // console.dir(error)
  if (error.response.status === 400) {
    Message.error('账号或密码错误')
  } else {
    if (error.response.status === 405) {
      Message.error('系统错误')
    }
  }
  return Promise.reject(error)
})

export default service
